home *** CD-ROM | disk | FTP | other *** search
/ FishMarket 1.0 / FishMarket v1.0.iso / fishies / 001-025 / disk_008 / src / hack.mkobj.c < prev    next >
C/C++ Source or Header  |  1992-05-06  |  3KB  |  143 lines

  1. /* Copyright (c) Stichting Mathematisch Centrum, Amsterdam, 1985. */
  2. /* hack.mkobc version 1.0.1 - mksobj() also in MKLEV */
  3.  
  4. #include "hack.h"
  5.  
  6. #include "hack.onames.h"
  7.  
  8. char mkobjstr[] = "))[[!!!!????%%%%/=**))[[!!!!????%%%%/=**(";
  9. struct obj *mkobj(), *mksobj();
  10.  
  11. mkobj_at(let,x,y)
  12. register int let,x,y;
  13. {
  14.     register struct obj *otmp = mkobj(let);
  15.     otmp->ox = x;
  16.     otmp->oy = y;
  17.     otmp->nobj = fobj;
  18.     fobj = otmp;
  19. }
  20.  
  21. mksobj_at(let,otyp,x,y)
  22. register int let,otyp,x,y;
  23. {
  24.     register struct obj *otmp = mksobj(let, otyp);
  25.     otmp->ox = x;
  26.     otmp->oy = y;
  27.     otmp->nobj = fobj;
  28.     fobj = otmp;
  29. }
  30.  
  31. struct obj *
  32. mkobj(let) {
  33.     if(!let) let = mkobjstr[rn2(sizeof(mkobjstr) - 1)];
  34.     return(mksobj(let, letter(let) ? CORPSE : probtype(let)));
  35. }
  36.     
  37.  
  38. struct obj zeroobj;
  39.  
  40. struct obj *
  41. mksobj(let, otyp) {
  42.     register struct obj *otmp;
  43.  
  44.     otmp = newobj(0);
  45.     *otmp = zeroobj;
  46.     otmp->age = (ismklev) ? 0 : moves;
  47.     otmp->o_id = flags.ident++;
  48.     otmp->quan = 1;
  49.     if(letter(let)){
  50.         otmp->olet = FOOD_SYM;
  51.         otmp->otyp = CORPSE + ((let > 'Z') ? (let-'a'+'Z'-'@'+1) :
  52.                 (let-'@'));
  53.         otmp->spe = let;
  54.         otmp->known = 1;
  55.         otmp->owt = weight(otmp);
  56.         return(otmp);
  57.     }
  58.     otmp->olet = let;
  59.     otmp->otyp = otyp;
  60.     otmp->dknown = index("/=!?*", let) ? 0 : 1;
  61.     switch(let) {
  62.     case WEAPON_SYM:
  63.         otmp->quan = (otmp->otyp <= ROCK) ? rn1(6,6) : 1;
  64.         if(!rn2(11)) otmp->spe = rnd(3);
  65.         else if(!rn2(10)) {
  66.             otmp->cursed = 1;
  67.             otmp->spe = -rnd(3);
  68.         }
  69.         break;
  70.     case FOOD_SYM:
  71.     case GEM_SYM:
  72.         otmp->quan = rn2(6) ? 1 : 2;
  73.     case TOOL_SYM:
  74.     case CHAIN_SYM:
  75.     case BALL_SYM:
  76.     case ROCK_SYM:
  77.     case POTION_SYM:
  78.     case SCROLL_SYM:
  79.     case AMULET_SYM:
  80.         break;
  81.     case ARMOR_SYM:
  82.         if(!rn2(8)) otmp->cursed = 1;
  83.         if(!rn2(10)) otmp->spe = rnd(3);
  84.         else if(!rn2(9)) {
  85.             otmp->spe = -rnd(3);
  86.             otmp->cursed = 1;
  87.         }
  88.         otmp->spe += 10 - objects[otmp->otyp].a_ac;
  89.         break;
  90.     case WAND_SYM:
  91.         if(otmp->otyp == WAN_WISHING) otmp->spe = 3; else
  92.         otmp->spe = rn1(5,
  93.             (objects[otmp->otyp].bits & NODIR) ? 11 : 4);
  94.         break;
  95.     case RING_SYM:
  96.         if(objects[otmp->otyp].bits & SPEC) {
  97.             if(!rn2(3)) {
  98.                 otmp->cursed = 1;
  99.                 otmp->spe = -rnd(2);
  100.             } else otmp->spe = rnd(2);
  101.         } else if(otmp->otyp == RIN_TELEPORTATION ||
  102.               otmp->otyp == RIN_AGGRAVATE_MONSTER ||
  103.               otmp->otyp == RIN_HUNGER || !rn2(9))
  104.             otmp->cursed = 1;
  105.         break;
  106.     default:
  107.         panic("impossible mkobj");
  108.     }
  109.     otmp->owt = weight(otmp);
  110.     return(otmp);
  111. }
  112.  
  113. letter(c) {
  114.     return(('@' <= c && c <= 'Z') || ('a' <= c && c <= 'z'));
  115. }
  116.  
  117. weight(obj)
  118. register struct obj *obj;
  119. {
  120. register int wt = objects[obj->otyp].oc_weight;
  121.     return(wt ? wt*obj->quan : (obj->quan + 1)/2);
  122. }
  123.  
  124. mkgold(num,x,y)
  125. register int num;
  126. {
  127.     register struct gen *gtmp;
  128.     register int amount = num ? num : 1 + (rnd(dlevel+2) * rnd(30));
  129.  
  130.     if(gtmp = g_at(x,y,fgold))
  131.         gtmp->gflag += amount;
  132.     else {
  133.         gtmp = newgen();
  134.         gtmp->ngen = fgold;
  135.         gtmp->gx = x;
  136.         gtmp->gy = y;
  137.         gtmp->gflag = amount;
  138.         fgold = gtmp;
  139.                 if (ismklev)
  140.            levl[x][y].scrsym = '$';
  141.     }
  142. }
  143.